package com.liangsiwei.weblog.common.domain.mapper;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.liangsiwei.weblog.common.domain.dos.CategoryDO;
import com.liangsiwei.weblog.common.domain.dos.TagDO;

import java.time.LocalDate;
import java.util.Objects;

public interface CategoryMapper extends BaseMapper<CategoryDO> {
    /**
    * 查询分类分页数据
    * @return 分类分页数据
    * */
    default Page<CategoryDO> selectPageList(Long current, Long size, String name, LocalDate startDate , LocalDate endDate)
        {
            // 分页对象(查询第几页、每页多少数据)
            Page<CategoryDO> page = new Page<>(current, size);

            // 构建查询条件
            LambdaQueryWrapper<CategoryDO> wrapper = new LambdaQueryWrapper<>();

            wrapper
                    .like(StringUtils.isNotBlank(name), CategoryDO::getName, name.trim())//like模块查询
                    .ge(Objects.nonNull(startDate), CategoryDO::getCreateTime, startDate)//大于等于stratDate
                    .le(Objects.nonNull(endDate), CategoryDO::getCreateTime, endDate)//小于等于endDate
                    .orderByDesc(CategoryDO::getCreateTime); // 按创建时间倒叙

            return selectPage(page, wrapper);
        }

    /**
     * 根据用户名查询
     * @param categoryName
     * @return
     */
    default CategoryDO selectByName(String categoryName) {
        // 构建查询条件
        //判断一下添加的分类是否存在
        LambdaQueryWrapper<CategoryDO> wrapper = new LambdaQueryWrapper<>();
        wrapper.eq(CategoryDO::getName, categoryName);

        // 执行查询
        return selectOne(wrapper);
    }

}
